package com.skh.string;

/**
 * @Author: skh
 * @Date: 2020/3/17 10:37
 * @Description: 拼写单词
 */
public class CountCharacters {

    /**
     * 给你一份『词汇表』（字符串数组） words 和一张『字母表』（字符串） chars。
     *
     * 假如你可以用 chars 中的『字母』（字符）拼写出 words 中的某个『单词』（字符串），那么我们就认为你掌握了这个单词。
     *
     * 注意：每次拼写时，chars 中的每个字母都只能用一次。
     *
     * 返回词汇表 words 中你掌握的所有单词的 长度之和。
     *
     * 示例 1：
     *
     * 输入：words = ["cat","bt","hat","tree"], chars = "atach"
     * 输出：6
     * 解释：
     * 可以形成字符串 "cat" 和 "hat"，所以答案是 3 + 3 = 6。
     * 示例 2：
     *
     * 输入：words = ["hello","world","leetcode"], chars = "welldonehoneyr"
     * 输出：10
     * 解释：
     * 可以形成字符串 "hello" 和 "world"，所以答案是 5 + 5 = 10。
     *
     * 提示：
     *
     * 1 <= words.length <= 1000
     * 1 <= words[i].length, chars.length <= 100
     * 所有字符串中都仅包含小写英文字母
     *
     */

    /**
     *
     * @param words
     * @param chars
     * @return
     */
    public int countCharacters(String[] words, String chars) {
        int[] charsCount = count(chars);
        int length = 0;
        for (String word : words) {
            int[] wordCount = count(word);
            boolean valid = true;
            for (int i = 0; i < 26; i++) {
                if (charsCount[i] < wordCount[i]) {
                    valid = false;
                }
            }
            if (valid) {
                length += word.length();
            }
        }


        return length;
    }

    // 统计 26 个字母出现的次数
    public int[] count(String word) {
        int[] count = new int[26];
        char[] chars = word.toCharArray();
        for (char c : chars) {
            count[c-'a']++;
        }
        return count;
    }
}
